

<!DOCTYPE html>
<html lang="zh-CN" data-default-color-scheme=auto>



<head>
  <meta charset="UTF-8">
  <link rel="apple-touch-icon" sizes="76x76" href="/img/fluid.png">
  <link rel="icon" href="/img/fluid.png">
  <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=5.0, shrink-to-fit=no">
  <meta http-equiv="x-ua-compatible" content="ie=edge">
  
  <meta name="theme-color" content="#2f4154">
  <meta name="author" content="叶飞">
  <meta name="keywords" content="">
  
    <meta name="description" content="原文地址：https:&#x2F;&#x2F;shockerli.net&#x2F;post&#x2F;1000-line-mysql-note&#x2F; ，JavaGuide 对本文进行了简答排版，新增了目录。 作者：格物  非常不错的总结，强烈建议保存下来，需要的时候看一看。  #基本操作 123456789&#x2F;* Windows服务 *&#x2F;-- 启动MySQL    net start mysql-- 创建Windows服务    sc c">
<meta property="og:type" content="article">
<meta property="og:title" content="Mysql学习笔记">
<meta property="og:url" content="http://example.com/2022/04/06/20220406-Mysql%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0/index.html">
<meta property="og:site_name" content="博客">
<meta property="og:description" content="原文地址：https:&#x2F;&#x2F;shockerli.net&#x2F;post&#x2F;1000-line-mysql-note&#x2F; ，JavaGuide 对本文进行了简答排版，新增了目录。 作者：格物  非常不错的总结，强烈建议保存下来，需要的时候看一看。  #基本操作 123456789&#x2F;* Windows服务 *&#x2F;-- 启动MySQL    net start mysql-- 创建Windows服务    sc c">
<meta property="og:locale" content="zh_CN">
<meta property="article:published_time" content="2022-04-06T11:43:53.000Z">
<meta property="article:modified_time" content="2022-04-06T11:52:19.589Z">
<meta property="article:author" content="叶飞">
<meta property="article:tag" content="MySQL">
<meta name="twitter:card" content="summary_large_image">
  
  
  
  <title>Mysql学习笔记 - 博客</title>

  <link  rel="stylesheet" href="https://lib.baomitu.com/twitter-bootstrap/4.6.1/css/bootstrap.min.css" />



  <link  rel="stylesheet" href="https://lib.baomitu.com/github-markdown-css/4.0.0/github-markdown.min.css" />

  <link  rel="stylesheet" href="https://lib.baomitu.com/hint.css/2.7.0/hint.min.css" />

  <link  rel="stylesheet" href="https://lib.baomitu.com/fancybox/3.5.7/jquery.fancybox.min.css" />



<!-- 主题依赖的图标库，不要自行修改 -->
<!-- Do not modify the link that theme dependent icons -->

<link rel="stylesheet" href="//at.alicdn.com/t/font_1749284_hj8rtnfg7um.css">



<link rel="stylesheet" href="//at.alicdn.com/t/font_1736178_lbnruvf0jn.css">


<link  rel="stylesheet" href="/css/main.css" />


  <link id="highlight-css" rel="stylesheet" href="/css/highlight.css" />
  
    <link id="highlight-css-dark" rel="stylesheet" href="/css/highlight-dark.css" />
  




  <script id="fluid-configs">
    var Fluid = window.Fluid || {};
    Fluid.ctx = Object.assign({}, Fluid.ctx)
    var CONFIG = {"hostname":"example.com","root":"/","version":"1.9.2","typing":{"enable":true,"typeSpeed":70,"cursorChar":"_","loop":false,"scope":[]},"anchorjs":{"enable":true,"element":"h1,h2,h3,h4,h5,h6","placement":"left","visible":"hover","icon":""},"progressbar":{"enable":true,"height_px":3,"color":"#29d","options":{"showSpinner":false,"trickleSpeed":100}},"code_language":{"enable":true,"default":"TEXT"},"copy_btn":true,"image_caption":{"enable":true},"image_zoom":{"enable":true,"img_url_replace":["",""]},"toc":{"enable":true,"placement":"right","headingSelector":"h1,h2,h3,h4,h5,h6","collapseDepth":0},"lazyload":{"enable":true,"loading_img":"/img/loading.gif","onlypost":false,"offset_factor":2},"web_analytics":{"enable":false,"follow_dnt":true,"baidu":null,"google":null,"gtag":null,"tencent":{"sid":null,"cid":null},"woyaola":null,"cnzz":null,"leancloud":{"app_id":null,"app_key":null,"server_url":null,"path":"window.location.pathname","ignore_local":false}},"search_path":"/local-search.xml"};

    if (CONFIG.web_analytics.follow_dnt) {
      var dntVal = navigator.doNotTrack || window.doNotTrack || navigator.msDoNotTrack;
      Fluid.ctx.dnt = dntVal && (dntVal.startsWith('1') || dntVal.startsWith('yes') || dntVal.startsWith('on'));
    }
  </script>
  <script  src="/js/utils.js" ></script>
  <script  src="/js/color-schema.js" ></script>
  


  
<meta name="generator" content="Hexo 6.2.0"></head>


<body>
  

  <header>
    

<div class="header-inner" style="height: 70vh;">
  <nav id="navbar" class="navbar fixed-top  navbar-expand-lg navbar-dark scrolling-navbar">
  <div class="container">
    <a class="navbar-brand" href="/">
      <strong>No Tomorrow</strong>
    </a>

    <button id="navbar-toggler-btn" class="navbar-toggler" type="button" data-toggle="collapse"
            data-target="#navbarSupportedContent"
            aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
      <div class="animated-icon"><span></span><span></span><span></span></div>
    </button>

    <!-- Collapsible content -->
    <div class="collapse navbar-collapse" id="navbarSupportedContent">
      <ul class="navbar-nav ml-auto text-center">
        
          
          
          
          
            <li class="nav-item">
              <a class="nav-link" href="/">
                <i class="iconfont icon-home-fill"></i>
                首页
              </a>
            </li>
          
        
          
          
          
          
            <li class="nav-item">
              <a class="nav-link" href="/archives/">
                <i class="iconfont icon-archive-fill"></i>
                归档
              </a>
            </li>
          
        
          
          
          
          
            <li class="nav-item">
              <a class="nav-link" href="/categories/">
                <i class="iconfont icon-category-fill"></i>
                分类
              </a>
            </li>
          
        
          
          
          
          
            <li class="nav-item">
              <a class="nav-link" href="/tags/">
                <i class="iconfont icon-tags-fill"></i>
                标签
              </a>
            </li>
          
        
          
          
          
          
            <li class="nav-item">
              <a class="nav-link" href="/about/">
                <i class="iconfont icon-user-fill"></i>
                关于
              </a>
            </li>
          
        
        
          <li class="nav-item" id="search-btn">
            <a class="nav-link" target="_self" href="javascript:;" data-toggle="modal" data-target="#modalSearch" aria-label="Search">
              &nbsp;<i class="iconfont icon-search"></i>&nbsp;
            </a>
          </li>
          
        
        
          <li class="nav-item" id="color-toggle-btn">
            <a class="nav-link" target="_self" href="javascript:;" aria-label="Color Toggle">&nbsp;<i
                class="iconfont icon-dark" id="color-toggle-icon"></i>&nbsp;</a>
          </li>
        
      </ul>
    </div>
  </div>
</nav>

  

<div id="banner" class="banner" parallax=true
     style="background: url('/img/default.png') no-repeat center center; background-size: cover;">
  <div class="full-bg-img">
    <div class="mask flex-center" style="background-color: rgba(0, 0, 0, 0.3)">
      <div class="banner-text text-center fade-in-up">
        <div class="h2">
          
            <span id="subtitle" data-typed-text="Mysql学习笔记"></span>
          
        </div>

        
          
  <div class="mt-3">
    
      <span class="post-meta mr-2">
        <i class="iconfont icon-author" aria-hidden="true"></i>
        叶飞
      </span>
    
    
      <span class="post-meta">
        <i class="iconfont icon-date-fill" aria-hidden="true"></i>
        <time datetime="2022-04-06 19:43" pubdate>
          星期三, 四月 6日 2022, 7:43 晚上
        </time>
      </span>
    
  </div>

  <div class="mt-1">
    
      <span class="post-meta mr-2">
        <i class="iconfont icon-chart"></i>
        
          <!-- compatible with older versions-->
          22k 字
        
      </span>
    

    
      <span class="post-meta mr-2">
        <i class="iconfont icon-clock-fill"></i>
        
        
        
          <!-- compatible with older versions-->
          185 分钟
        
      </span>
    

    
    
      
        <span id="leancloud-page-views-container" class="post-meta" style="display: none">
          <i class="iconfont icon-eye" aria-hidden="true"></i>
          <span id="leancloud-page-views"></span> 次
        </span>
        
      
    
  </div>


        
      </div>

      
    </div>
  </div>
</div>

</div>

  </header>

  <main>
    
      

<div class="container-fluid nopadding-x">
  <div class="row nomargin-x">
    <div class="side-col d-none d-lg-block col-lg-2">
      

    </div>

    <div class="col-lg-8 nopadding-x-md">
      <div class="container nopadding-x-md" id="board-ctn">
        <div id="board">
          <article class="post-content mx-auto">
            <!-- SEO header -->
            <h1 style="display: none">Mysql学习笔记</h1>
            
            
              <div class="markdown-body">
                
                <blockquote>
<p>原文地址：<a target="_blank" rel="noopener" href="https://shockerli.net/post/1000-line-mysql-note/">https://shockerli.net/post/1000-line-mysql-note/</a> ，JavaGuide 对本文进行了简答排版，新增了目录。 作者：格物</p>
</blockquote>
<p>非常不错的总结，强烈建议保存下来，需要的时候看一看。</p>
<h3 id><a class="markdownIt-Anchor" href="#"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#%E5%9F%BA%E6%9C%AC%E6%93%8D%E4%BD%9C">#</a>基本操作</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br></pre></td><td class="code"><pre><code class="hljs mysql">/* Windows服务 */<br>-- 启动MySQL<br>    net start mysql<br>-- 创建Windows服务<br>    sc create mysql binPath= mysqld_bin_path(注意：等号与值之间有空格)<br>/* 连接与断开服务器 */<br>mysql -h 地址 -P 端口 -u 用户名 -p 密码<br>SHOW PROCESSLIST -- 显示哪些线程正在运行<br>SHOW VARIABLES -- 显示系统变量信息<br></code></pre></td></tr></table></figure>
<h3 id="-2"><a class="markdownIt-Anchor" href="#-2"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#%E6%95%B0%E6%8D%AE%E5%BA%93%E6%93%8D%E4%BD%9C">#</a>数据库操作</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br></pre></td><td class="code"><pre><code class="hljs mysql">/* 数据库操作 */ ------------------<br>-- 查看当前数据库<br>    SELECT DATABASE();<br>-- 显示当前时间、用户名、数据库版本<br>    SELECT now(), user(), version();<br>-- 创建库<br>    CREATE DATABASE[ IF NOT EXISTS] 数据库名 数据库选项<br>    数据库选项：<br>        CHARACTER SET charset_name<br>        COLLATE collation_name<br>-- 查看已有库<br>    SHOW DATABASES[ LIKE &#x27;PATTERN&#x27;]<br>-- 查看当前库信息<br>    SHOW CREATE DATABASE 数据库名<br>-- 修改库的选项信息<br>    ALTER DATABASE 库名 选项信息<br>-- 删除库<br>    DROP DATABASE[ IF EXISTS] 数据库名<br>        同时删除该数据库相关的目录及其目录内容<br></code></pre></td></tr></table></figure>
<h3 id="-3"><a class="markdownIt-Anchor" href="#-3"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#%E8%A1%A8%E7%9A%84%E6%93%8D%E4%BD%9C">#</a>表的操作</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br><span class="line">24</span><br><span class="line">25</span><br><span class="line">26</span><br><span class="line">27</span><br><span class="line">28</span><br><span class="line">29</span><br><span class="line">30</span><br><span class="line">31</span><br><span class="line">32</span><br><span class="line">33</span><br><span class="line">34</span><br><span class="line">35</span><br><span class="line">36</span><br><span class="line">37</span><br><span class="line">38</span><br><span class="line">39</span><br><span class="line">40</span><br><span class="line">41</span><br><span class="line">42</span><br><span class="line">43</span><br><span class="line">44</span><br><span class="line">45</span><br><span class="line">46</span><br><span class="line">47</span><br><span class="line">48</span><br><span class="line">49</span><br><span class="line">50</span><br><span class="line">51</span><br><span class="line">52</span><br><span class="line">53</span><br><span class="line">54</span><br><span class="line">55</span><br><span class="line">56</span><br><span class="line">57</span><br><span class="line">58</span><br><span class="line">59</span><br><span class="line">60</span><br><span class="line">61</span><br><span class="line">62</span><br><span class="line">63</span><br><span class="line">64</span><br><span class="line">65</span><br><span class="line">66</span><br><span class="line">67</span><br><span class="line">68</span><br><span class="line">69</span><br><span class="line">70</span><br><span class="line">71</span><br><span class="line">72</span><br><span class="line">73</span><br><span class="line">74</span><br><span class="line">75</span><br><span class="line">76</span><br></pre></td><td class="code"><pre><code class="hljs mysql">-- 创建表<br>    CREATE [TEMPORARY] TABLE[ IF NOT EXISTS] [库名.]表名 ( 表的结构定义 )[ 表选项]<br>        每个字段必须有数据类型<br>        最后一个字段后不能有逗号<br>        TEMPORARY 临时表，会话结束时表自动消失<br>        对于字段的定义：<br>            字段名 数据类型 [NOT NULL | NULL] [DEFAULT default_value] [AUTO_INCREMENT] [UNIQUE [KEY] | [PRIMARY] KEY] [COMMENT &#x27;string&#x27;]<br>-- 表选项<br>    -- 字符集<br>        CHARSET = charset_name<br>        如果表没有设定，则使用数据库字符集<br>    -- 存储引擎<br>        ENGINE = engine_name<br>        表在管理数据时采用的不同的数据结构，结构不同会导致处理方式、提供的特性操作等不同<br>        常见的引擎：InnoDB MyISAM Memory/Heap BDB Merge Example CSV MaxDB Archive<br>        不同的引擎在保存表的结构和数据时采用不同的方式<br>        MyISAM表文件含义：.frm表定义，.MYD表数据，.MYI表索引<br>        InnoDB表文件含义：.frm表定义，表空间数据和日志文件<br>        SHOW ENGINES -- 显示存储引擎的状态信息<br>        SHOW ENGINE 引擎名 &#123;LOGS|STATUS&#125; -- 显示存储引擎的日志或状态信息<br>    -- 自增起始数<br>    	AUTO_INCREMENT = 行数<br>    -- 数据文件目录<br>        DATA DIRECTORY = &#x27;目录&#x27;<br>    -- 索引文件目录<br>        INDEX DIRECTORY = &#x27;目录&#x27;<br>    -- 表注释<br>        COMMENT = &#x27;string&#x27;<br>    -- 分区选项<br>        PARTITION BY ... (详细见手册)<br>-- 查看所有表<br>    SHOW TABLES[ LIKE &#x27;pattern&#x27;]<br>    SHOW TABLES FROM  库名<br>-- 查看表结构<br>    SHOW CREATE TABLE 表名 （信息更详细）<br>    DESC 表名 / DESCRIBE 表名 / EXPLAIN 表名 / SHOW COLUMNS FROM 表名 [LIKE &#x27;PATTERN&#x27;]<br>    SHOW TABLE STATUS [FROM db_name] [LIKE &#x27;pattern&#x27;]<br>-- 修改表<br>    -- 修改表本身的选项<br>        ALTER TABLE 表名 表的选项<br>        eg: ALTER TABLE 表名 ENGINE=MYISAM;<br>    -- 对表进行重命名<br>        RENAME TABLE 原表名 TO 新表名<br>        RENAME TABLE 原表名 TO 库名.表名 （可将表移动到另一个数据库）<br>        -- RENAME可以交换两个表名<br>    -- 修改表的字段机构（13.1.2. ALTER TABLE语法）<br>        ALTER TABLE 表名 操作名<br>        -- 操作名<br>            ADD[ COLUMN] 字段定义       -- 增加字段<br>                AFTER 字段名          -- 表示增加在该字段名后面<br>                FIRST               -- 表示增加在第一个<br>            ADD PRIMARY KEY(字段名)   -- 创建主键<br>            ADD UNIQUE [索引名] (字段名)-- 创建唯一索引<br>            ADD INDEX [索引名] (字段名) -- 创建普通索引<br>            DROP[ COLUMN] 字段名      -- 删除字段<br>            MODIFY[ COLUMN] 字段名 字段属性     -- 支持对字段属性进行修改，不能修改字段名(所有原有属性也需写上)<br>            CHANGE[ COLUMN] 原字段名 新字段名 字段属性      -- 支持对字段名修改<br>            DROP PRIMARY KEY    -- 删除主键(删除主键前需删除其AUTO_INCREMENT属性)<br>            DROP INDEX 索引名 -- 删除索引<br>            DROP FOREIGN KEY 外键    -- 删除外键<br>-- 删除表<br>    DROP TABLE[ IF EXISTS] 表名 ...<br>-- 清空表数据<br>    TRUNCATE [TABLE] 表名<br>-- 复制表结构<br>    CREATE TABLE 表名 LIKE 要复制的表名<br>-- 复制表结构和数据<br>    CREATE TABLE 表名 [AS] SELECT * FROM 要复制的表名<br>-- 检查表是否有错误<br>    CHECK TABLE tbl_name [, tbl_name] ... [option] ...<br>-- 优化表<br>    OPTIMIZE [LOCAL | NO_WRITE_TO_BINLOG] TABLE tbl_name [, tbl_name] ...<br>-- 修复表<br>    REPAIR [LOCAL | NO_WRITE_TO_BINLOG] TABLE tbl_name [, tbl_name] ... [QUICK] [EXTENDED] [USE_FRM]<br>-- 分析表<br>    ANALYZE [LOCAL | NO_WRITE_TO_BINLOG] TABLE tbl_name [, tbl_name] ...<br></code></pre></td></tr></table></figure>
<h3 id="-4"><a class="markdownIt-Anchor" href="#-4"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#%E6%95%B0%E6%8D%AE%E6%93%8D%E4%BD%9C">#</a>数据操作</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br></pre></td><td class="code"><pre><code class="hljs mysql">/* 数据操作 */ ------------------<br>-- 增<br>    INSERT [INTO] 表名 [(字段列表)] VALUES (值列表)[, (值列表), ...]<br>        -- 如果要插入的值列表包含所有字段并且顺序一致，则可以省略字段列表。<br>        -- 可同时插入多条数据记录！<br>        REPLACE 与 INSERT 完全一样，可互换。<br>    INSERT [INTO] 表名 SET 字段名=值[, 字段名=值, ...]<br>-- 查<br>    SELECT 字段列表 FROM 表名[ 其他子句]<br>        -- 可来自多个表的多个字段<br>        -- 其他子句可以不使用<br>        -- 字段列表可以用*代替，表示所有字段<br>-- 删<br>    DELETE FROM 表名[ 删除条件子句]<br>        没有条件子句，则会删除全部<br>-- 改<br>    UPDATE 表名 SET 字段名=新值[, 字段名=新值] [更新条件]<br></code></pre></td></tr></table></figure>
<h3 id="-5"><a class="markdownIt-Anchor" href="#-5"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#%E5%AD%97%E7%AC%A6%E9%9B%86%E7%BC%96%E7%A0%81">#</a>字符集编码</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br></pre></td><td class="code"><pre><code class="hljs mysql">/* 字符集编码 */ ------------------<br>-- MySQL、数据库、表、字段均可设置编码<br>-- 数据编码与客户端编码不需一致<br>SHOW VARIABLES LIKE &#x27;character_set_%&#x27;   -- 查看所有字符集编码项<br>    character_set_client        客户端向服务器发送数据时使用的编码<br>    character_set_results       服务器端将结果返回给客户端所使用的编码<br>    character_set_connection    连接层编码<br>SET 变量名 = 变量值<br>    SET character_set_client = gbk;<br>    SET character_set_results = gbk;<br>    SET character_set_connection = gbk;<br>SET NAMES GBK;  -- 相当于完成以上三个设置<br>-- 校对集<br>    校对集用以排序<br>    SHOW CHARACTER SET [LIKE &#x27;pattern&#x27;]/SHOW CHARSET [LIKE &#x27;pattern&#x27;]   查看所有字符集<br>    SHOW COLLATION [LIKE &#x27;pattern&#x27;]     查看所有校对集<br>    CHARSET 字符集编码     设置字符集编码<br>    COLLATE 校对集编码     设置校对集编码<br></code></pre></td></tr></table></figure>
<h3 id="-6"><a class="markdownIt-Anchor" href="#-6"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#%E6%95%B0%E6%8D%AE%E7%B1%BB%E5%9E%8B-%E5%88%97%E7%B1%BB%E5%9E%8B">#</a>数据类型(列类型)</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br><span class="line">24</span><br><span class="line">25</span><br><span class="line">26</span><br><span class="line">27</span><br><span class="line">28</span><br><span class="line">29</span><br><span class="line">30</span><br><span class="line">31</span><br><span class="line">32</span><br><span class="line">33</span><br><span class="line">34</span><br><span class="line">35</span><br><span class="line">36</span><br><span class="line">37</span><br><span class="line">38</span><br><span class="line">39</span><br><span class="line">40</span><br><span class="line">41</span><br><span class="line">42</span><br><span class="line">43</span><br><span class="line">44</span><br><span class="line">45</span><br><span class="line">46</span><br><span class="line">47</span><br><span class="line">48</span><br><span class="line">49</span><br><span class="line">50</span><br><span class="line">51</span><br><span class="line">52</span><br><span class="line">53</span><br><span class="line">54</span><br><span class="line">55</span><br><span class="line">56</span><br><span class="line">57</span><br><span class="line">58</span><br><span class="line">59</span><br><span class="line">60</span><br><span class="line">61</span><br><span class="line">62</span><br><span class="line">63</span><br><span class="line">64</span><br><span class="line">65</span><br><span class="line">66</span><br><span class="line">67</span><br><span class="line">68</span><br><span class="line">69</span><br><span class="line">70</span><br><span class="line">71</span><br><span class="line">72</span><br><span class="line">73</span><br><span class="line">74</span><br><span class="line">75</span><br><span class="line">76</span><br><span class="line">77</span><br><span class="line">78</span><br><span class="line">79</span><br><span class="line">80</span><br><span class="line">81</span><br><span class="line">82</span><br><span class="line">83</span><br><span class="line">84</span><br><span class="line">85</span><br><span class="line">86</span><br><span class="line">87</span><br><span class="line">88</span><br><span class="line">89</span><br><span class="line">90</span><br><span class="line">91</span><br><span class="line">92</span><br><span class="line">93</span><br><span class="line">94</span><br><span class="line">95</span><br><span class="line">96</span><br><span class="line">97</span><br></pre></td><td class="code"><pre><code class="hljs mysql">/* 数据类型（列类型） */ ------------------<br>1. 数值类型<br>-- a. 整型 ----------<br>    类型         字节     范围（有符号位）<br>    tinyint     1字节    -128 ~ 127      无符号位：0 ~ 255<br>    smallint    2字节    -32768 ~ 32767<br>    mediumint   3字节    -8388608 ~ 8388607<br>    int         4字节<br>    bigint      8字节<br>    int(M)  M表示总位数<br>    - 默认存在符号位，unsigned 属性修改<br>    - 显示宽度，如果某个数不够定义字段时设置的位数，则前面以0补填，zerofill 属性修改<br>        例：int(5)   插入一个数&#x27;123&#x27;，补填后为&#x27;00123&#x27;<br>    - 在满足要求的情况下，越小越好。<br>    - 1表示bool值真，0表示bool值假。MySQL没有布尔类型，通过整型0和1表示。常用tinyint(1)表示布尔型。<br>-- b. 浮点型 ----------<br>    类型             字节     范围<br>    float(单精度)     4字节<br>    double(双精度)    8字节<br>    浮点型既支持符号位 unsigned 属性，也支持显示宽度 zerofill 属性。<br>        不同于整型，前后均会补填0.<br>    定义浮点型时，需指定总位数和小数位数。<br>        float(M, D)     double(M, D)<br>        M表示总位数，D表示小数位数。<br>        M和D的大小会决定浮点数的范围。不同于整型的固定范围。<br>        M既表示总位数（不包括小数点和正负号），也表示显示宽度（所有显示符号均包括）。<br>        支持科学计数法表示。<br>        浮点数表示近似值。<br>-- c. 定点数 ----------<br>    decimal -- 可变长度<br>    decimal(M, D)   M也表示总位数，D表示小数位数。<br>    保存一个精确的数值，不会发生数据的改变，不同于浮点数的四舍五入。<br>    将浮点数转换为字符串来保存，每9位数字保存为4个字节。<br>2. 字符串类型<br>-- a. char, varchar ----------<br>    char    定长字符串，速度快，但浪费空间<br>    varchar 变长字符串，速度慢，但节省空间<br>    M表示能存储的最大长度，此长度是字符数，非字节数。<br>    不同的编码，所占用的空间不同。<br>    char,最多255个字符，与编码无关。<br>    varchar,最多65535字符，与编码有关。<br>    一条有效记录最大不能超过65535个字节。<br>        utf8 最大为21844个字符，gbk 最大为32766个字符，latin1 最大为65532个字符<br>    varchar 是变长的，需要利用存储空间保存 varchar 的长度，如果数据小于255个字节，则采用一个字节来保存长度，反之需要两个字节来保存。<br>    varchar 的最大有效长度由最大行大小和使用的字符集确定。<br>    最大有效长度是65532字节，因为在varchar存字符串时，第一个字节是空的，不存在任何数据，然后还需两个字节来存放字符串的长度，所以有效长度是65535-1-2=65532字节。<br>    例：若一个表定义为 CREATE TABLE tb(c1 int, c2 char(30), c3 varchar(N)) charset=utf8; 问N的最大值是多少？ 答：(65535-1-2-4-30*3)/3<br>-- b. blob, text ----------<br>    blob 二进制字符串（字节字符串）<br>        tinyblob, blob, mediumblob, longblob<br>    text 非二进制字符串（字符字符串）<br>        tinytext, text, mediumtext, longtext<br>    text 在定义时，不需要定义长度，也不会计算总长度。<br>    text 类型在定义时，不可给default值<br>-- c. binary, varbinary ----------<br>    类似于char和varchar，用于保存二进制字符串，也就是保存字节字符串而非字符字符串。<br>    char, varchar, text 对应 binary, varbinary, blob.<br>3. 日期时间类型<br>    一般用整型保存时间戳，因为PHP可以很方便的将时间戳进行格式化。<br>    datetime    8字节    日期及时间     1000-01-01 00:00:00 到 9999-12-31 23:59:59<br>    date        3字节    日期         1000-01-01 到 9999-12-31<br>    timestamp   4字节    时间戳        19700101000000 到 2038-01-19 03:14:07<br>    time        3字节    时间         -838:59:59 到 838:59:59<br>    year        1字节    年份         1901 - 2155<br>datetime    YYYY-MM-DD hh:mm:ss<br>timestamp   YY-MM-DD hh:mm:ss<br>            YYYYMMDDhhmmss<br>            YYMMDDhhmmss<br>            YYYYMMDDhhmmss<br>            YYMMDDhhmmss<br>date        YYYY-MM-DD<br>            YY-MM-DD<br>            YYYYMMDD<br>            YYMMDD<br>            YYYYMMDD<br>            YYMMDD<br>time        hh:mm:ss<br>            hhmmss<br>            hhmmss<br>year        YYYY<br>            YY<br>            YYYY<br>            YY<br>4. 枚举和集合<br>-- 枚举(enum) ----------<br>enum(val1, val2, val3...)<br>    在已知的值中进行单选。最大数量为65535.<br>    枚举值在保存时，以2个字节的整型(smallint)保存。每个枚举值，按保存的位置顺序，从1开始逐一递增。<br>    表现为字符串类型，存储却是整型。<br>    NULL值的索引是NULL。<br>    空字符串错误值的索引值是0。<br>-- 集合（set） ----------<br>set(val1, val2, val3...)<br>    create table tab ( gender set(&#x27;男&#x27;, &#x27;女&#x27;, &#x27;无&#x27;) );<br>    insert into tab values (&#x27;男, 女&#x27;);<br>    最多可以有64个不同的成员。以bigint存储，共8个字节。采取位运算的形式。<br>    当创建表时，SET成员值的尾部空格将自动被删除。<br></code></pre></td></tr></table></figure>
<h3 id="-7"><a class="markdownIt-Anchor" href="#-7"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#%E5%88%97%E5%B1%9E%E6%80%A7-%E5%88%97%E7%BA%A6%E6%9D%9F">#</a>列属性(列约束)</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br><span class="line">24</span><br><span class="line">25</span><br><span class="line">26</span><br><span class="line">27</span><br><span class="line">28</span><br><span class="line">29</span><br><span class="line">30</span><br><span class="line">31</span><br><span class="line">32</span><br><span class="line">33</span><br><span class="line">34</span><br><span class="line">35</span><br><span class="line">36</span><br><span class="line">37</span><br><span class="line">38</span><br><span class="line">39</span><br><span class="line">40</span><br><span class="line">41</span><br><span class="line">42</span><br><span class="line">43</span><br><span class="line">44</span><br><span class="line">45</span><br><span class="line">46</span><br><span class="line">47</span><br><span class="line">48</span><br><span class="line">49</span><br></pre></td><td class="code"><pre><code class="hljs mysql">/* 列属性（列约束） */ ------------------<br>1. PRIMARY 主键<br>    - 能唯一标识记录的字段，可以作为主键。<br>    - 一个表只能有一个主键。<br>    - 主键具有唯一性。<br>    - 声明字段时，用 primary key 标识。<br>        也可以在字段列表之后声明<br>            例：create table tab ( id int, stu varchar(10), primary key (id));<br>    - 主键字段的值不能为null。<br>    - 主键可以由多个字段共同组成。此时需要在字段列表后声明的方法。<br>        例：create table tab ( id int, stu varchar(10), age int, primary key (stu, age));<br>2. UNIQUE 唯一索引（唯一约束）<br>    使得某字段的值也不能重复。<br>3. NULL 约束<br>    null不是数据类型，是列的一个属性。<br>    表示当前列是否可以为null，表示什么都没有。<br>    null, 允许为空。默认。<br>    not null, 不允许为空。<br>    insert into tab values (null, &#x27;val&#x27;);<br>        -- 此时表示将第一个字段的值设为null, 取决于该字段是否允许为null<br>4. DEFAULT 默认值属性<br>    当前字段的默认值。<br>    insert into tab values (default, &#x27;val&#x27;);    -- 此时表示强制使用默认值。<br>    create table tab ( add_time timestamp default current_timestamp );<br>        -- 表示将当前时间的时间戳设为默认值。<br>        current_date, current_time<br>5. AUTO_INCREMENT 自动增长约束<br>    自动增长必须为索引（主键或unique）<br>    只能存在一个字段为自动增长。<br>    默认为1开始自动增长。可以通过表属性 auto_increment = x进行设置，或 alter table tbl auto_increment = x;<br>6. COMMENT 注释<br>    例：create table tab ( id int ) comment &#x27;注释内容&#x27;;<br>7. FOREIGN KEY 外键约束<br>    用于限制主表与从表数据完整性。<br>    alter table t1 add constraint `t1_t2_fk` foreign key (t1_id) references t2(id);<br>        -- 将表t1的t1_id外键关联到表t2的id字段。<br>        -- 每个外键都有一个名字，可以通过 constraint 指定<br>    存在外键的表，称之为从表（子表），外键指向的表，称之为主表（父表）。<br>    作用：保持数据一致性，完整性，主要目的是控制存储在外键表（从表）中的数据。<br>    MySQL中，可以对InnoDB引擎使用外键约束：<br>    语法：<br>    foreign key (外键字段） references 主表名 (关联字段) [主表记录删除时的动作] [主表记录更新时的动作]<br>    此时需要检测一个从表的外键需要约束为主表的已存在的值。外键在没有关联的情况下，可以设置为null.前提是该外键列，没有not null。<br>    可以不指定主表记录更改或更新时的动作，那么此时主表的操作被拒绝。<br>    如果指定了 on update 或 on delete：在删除或更新时，有如下几个操作可以选择：<br>    1. cascade，级联操作。主表数据被更新（主键值更新），从表也被更新（外键值更新）。主表记录被删除，从表相关记录也被删除。<br>    2. set null，设置为null。主表数据被更新（主键值更新），从表的外键被设置为null。主表记录被删除，从表相关记录外键被设置成null。但注意，要求该外键列，没有not null属性约束。<br>    3. restrict，拒绝父表删除和更新。<br>    注意，外键只被InnoDB存储引擎所支持。其他引擎是不支持的。<br></code></pre></td></tr></table></figure>
<h3 id="-8"><a class="markdownIt-Anchor" href="#-8"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#%E5%BB%BA%E8%A1%A8%E8%A7%84%E8%8C%83">#</a>建表规范</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br></pre></td><td class="code"><pre><code class="hljs mysql">/* 建表规范 */ ------------------<br>    -- Normal Format, NF<br>        - 每个表保存一个实体信息<br>        - 每个具有一个ID字段作为主键<br>        - ID主键 + 原子表<br>    -- 1NF, 第一范式<br>        字段不能再分，就满足第一范式。<br>    -- 2NF, 第二范式<br>        满足第一范式的前提下，不能出现部分依赖。<br>        消除复合主键就可以避免部分依赖。增加单列关键字。<br>    -- 3NF, 第三范式<br>        满足第二范式的前提下，不能出现传递依赖。<br>        某个字段依赖于主键，而有其他字段依赖于该字段。这就是传递依赖。<br>        将一个实体信息的数据放在一个表内实现。<br></code></pre></td></tr></table></figure>
<h3 id="-9"><a class="markdownIt-Anchor" href="#-9"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#select">#</a>SELECT</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br><span class="line">24</span><br><span class="line">25</span><br><span class="line">26</span><br><span class="line">27</span><br><span class="line">28</span><br><span class="line">29</span><br><span class="line">30</span><br><span class="line">31</span><br><span class="line">32</span><br><span class="line">33</span><br><span class="line">34</span><br><span class="line">35</span><br><span class="line">36</span><br><span class="line">37</span><br><span class="line">38</span><br><span class="line">39</span><br><span class="line">40</span><br><span class="line">41</span><br><span class="line">42</span><br><span class="line">43</span><br><span class="line">44</span><br><span class="line">45</span><br><span class="line">46</span><br><span class="line">47</span><br><span class="line">48</span><br><span class="line">49</span><br><span class="line">50</span><br><span class="line">51</span><br><span class="line">52</span><br><span class="line">53</span><br><span class="line">54</span><br><span class="line">55</span><br><span class="line">56</span><br><span class="line">57</span><br><span class="line">58</span><br><span class="line">59</span><br><span class="line">60</span><br></pre></td><td class="code"><pre><code class="hljs mysql">/* SELECT */ ------------------<br>SELECT [ALL|DISTINCT] select_expr FROM -&gt; WHERE -&gt; GROUP BY [合计函数] -&gt; HAVING -&gt; ORDER BY -&gt; LIMIT<br>a. select_expr<br>    -- 可以用 * 表示所有字段。<br>        select * from tb;<br>    -- 可以使用表达式（计算公式、函数调用、字段也是个表达式）<br>        select stu, 29+25, now() from tb;<br>    -- 可以为每个列使用别名。适用于简化列标识，避免多个列标识符重复。<br>        - 使用 as 关键字，也可省略 as.<br>        select stu+10 as add10 from tb;<br>b. FROM 子句<br>    用于标识查询来源。<br>    -- 可以为表起别名。使用as关键字。<br>        SELECT * FROM tb1 AS tt, tb2 AS bb;<br>    -- from子句后，可以同时出现多个表。<br>        -- 多个表会横向叠加到一起，而数据会形成一个笛卡尔积。<br>        SELECT * FROM tb1, tb2;<br>    -- 向优化符提示如何选择索引<br>        USE INDEX、IGNORE INDEX、FORCE INDEX<br>        SELECT * FROM table1 USE INDEX (key1,key2) WHERE key1=1 AND key2=2 AND key3=3;<br>        SELECT * FROM table1 IGNORE INDEX (key3) WHERE key1=1 AND key2=2 AND key3=3;<br>c. WHERE 子句<br>    -- 从from获得的数据源中进行筛选。<br>    -- 整型1表示真，0表示假。<br>    -- 表达式由运算符和运算数组成。<br>        -- 运算数：变量（字段）、值、函数返回值<br>        -- 运算符：<br>            =, &lt;=&gt;, &lt;&gt;, !=, &lt;=, &lt;, &gt;=, &gt;, !, &amp;&amp;, ||,<br>            in (not) null, (not) like, (not) in, (not) between and, is (not), and, or, not, xor<br>            is/is not 加上ture/false/unknown，检验某个值的真假<br>            &lt;=&gt;与&lt;&gt;功能相同，&lt;=&gt;可用于null比较<br>d. GROUP BY 子句, 分组子句<br>    GROUP BY 字段/别名 [排序方式]<br>    分组后会进行排序。升序：ASC，降序：DESC<br>    以下[合计函数]需配合 GROUP BY 使用：<br>    count 返回不同的非NULL值数目  count(*)、count(字段)<br>    sum 求和<br>    max 求最大值<br>    min 求最小值<br>    avg 求平均值<br>    group_concat 返回带有来自一个组的连接的非NULL值的字符串结果。组内字符串连接。<br>e. HAVING 子句，条件子句<br>    与 where 功能、用法相同，执行时机不同。<br>    where 在开始时执行检测数据，对原数据进行过滤。<br>    having 对筛选出的结果再次进行过滤。<br>    having 字段必须是查询出来的，where 字段必须是数据表存在的。<br>    where 不可以使用字段的别名，having 可以。因为执行WHERE代码时，可能尚未确定列值。<br>    where 不可以使用合计函数。一般需用合计函数才会用 having<br>    SQL标准要求HAVING必须引用GROUP BY子句中的列或用于合计函数中的列。<br>f. ORDER BY 子句，排序子句<br>    order by 排序字段/别名 排序方式 [,排序字段/别名 排序方式]...<br>    升序：ASC，降序：DESC<br>    支持多个字段的排序。<br>g. LIMIT 子句，限制结果数量子句<br>    仅对处理好的结果进行数量限制。将处理好的结果的看作是一个集合，按照记录出现的顺序，索引从0开始。<br>    limit 起始位置, 获取条数<br>    省略第一个参数，表示从索引0开始。limit 获取条数<br>h. DISTINCT, ALL 选项<br>    distinct 去除重复记录<br>    默认为 all, 全部记录<br></code></pre></td></tr></table></figure>
<h3 id="-10"><a class="markdownIt-Anchor" href="#-10"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#union">#</a>UNION</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br></pre></td><td class="code"><pre><code class="hljs mysql">/* UNION */ ------------------<br>    将多个select查询的结果组合成一个结果集合。<br>    SELECT ... UNION [ALL|DISTINCT] SELECT ...<br>    默认 DISTINCT 方式，即所有返回的行都是唯一的<br>    建议，对每个SELECT查询加上小括号包裹。<br>    ORDER BY 排序时，需加上 LIMIT 进行结合。<br>    需要各select查询的字段数量一样。<br>    每个select查询的字段列表(数量、类型)应一致，因为结果中的字段名以第一条select语句为准。<br></code></pre></td></tr></table></figure>
<h3 id="-11"><a class="markdownIt-Anchor" href="#-11"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#%E5%AD%90%E6%9F%A5%E8%AF%A2">#</a>子查询</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br><span class="line">24</span><br><span class="line">25</span><br><span class="line">26</span><br><span class="line">27</span><br><span class="line">28</span><br><span class="line">29</span><br></pre></td><td class="code"><pre><code class="hljs mysql">/* 子查询 */ ------------------<br>    - 子查询需用括号包裹。<br>-- from型<br>    from后要求是一个表，必须给子查询结果取个别名。<br>    - 简化每个查询内的条件。<br>    - from型需将结果生成一个临时表格，可用以原表的锁定的释放。<br>    - 子查询返回一个表，表型子查询。<br>    select * from (select * from tb where id&gt;0) as subfrom where id&gt;1;<br>-- where型<br>    - 子查询返回一个值，标量子查询。<br>    - 不需要给子查询取别名。<br>    - where子查询内的表，不能直接用以更新。<br>    select * from tb where money = (select max(money) from tb);<br>    -- 列子查询<br>        如果子查询结果返回的是一列。<br>        使用 in 或 not in 完成查询<br>        exists 和 not exists 条件<br>            如果子查询返回数据，则返回1或0。常用于判断条件。<br>            select column1 from t1 where exists (select * from t2);<br>    -- 行子查询<br>        查询条件是一个行。<br>        select * from t1 where (id, gender) in (select id, gender from t2);<br>        行构造符：(col1, col2, ...) 或 ROW(col1, col2, ...)<br>        行构造符通常用于与对能返回两个或两个以上列的子查询进行比较。<br>    -- 特殊运算符<br>    != all()    相当于 not in<br>    = some()    相当于 in。any 是 some 的别名<br>    != some()   不等同于 not in，不等于其中某一个。<br>    all, some 可以配合其他运算符一起使用。<br></code></pre></td></tr></table></figure>
<h3 id="-12"><a class="markdownIt-Anchor" href="#-12"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#%E8%BF%9E%E6%8E%A5%E6%9F%A5%E8%AF%A2-join">#</a>连接查询(join)</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br><span class="line">24</span><br></pre></td><td class="code"><pre><code class="hljs mysql">/* 连接查询(join) */ ------------------<br>    将多个表的字段进行连接，可以指定连接条件。<br>-- 内连接(inner join)<br>    - 默认就是内连接，可省略inner。<br>    - 只有数据存在时才能发送连接。即连接结果不能出现空行。<br>    on 表示连接条件。其条件表达式与where类似。也可以省略条件（表示条件永远为真）<br>    也可用where表示连接条件。<br>    还有 using, 但需字段名相同。 using(字段名)<br>    -- 交叉连接 cross join<br>        即，没有条件的内连接。<br>        select * from tb1 cross join tb2;<br>-- 外连接(outer join)<br>    - 如果数据不存在，也会出现在连接结果中。<br>    -- 左外连接 left join<br>        如果数据不存在，左表记录会出现，而右表为null填充<br>    -- 右外连接 right join<br>        如果数据不存在，右表记录会出现，而左表为null填充<br>-- 自然连接(natural join)<br>    自动判断连接条件完成连接。<br>    相当于省略了using，会自动查找相同字段名。<br>    natural join<br>    natural left join<br>    natural right join<br>select info.id, info.name, info.stu_num, extra_info.hobby, extra_info.sex from info, extra_info where info.stu_num = extra_info.stu_id;<br></code></pre></td></tr></table></figure>
<h3 id="-13"><a class="markdownIt-Anchor" href="#-13"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#truncate">#</a>TRUNCATE</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br></pre></td><td class="code"><pre><code class="hljs mysql">/* TRUNCATE */ ------------------<br>TRUNCATE [TABLE] tbl_name<br>清空数据<br>删除重建表<br>区别：<br>1，truncate 是删除表再创建，delete 是逐条删除<br>2，truncate 重置auto_increment的值。而delete不会<br>3，truncate 不知道删除了几条，而delete知道。<br>4，当被用于带分区的表时，truncate 会保留分区<br></code></pre></td></tr></table></figure>
<h3 id="-14"><a class="markdownIt-Anchor" href="#-14"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#%E5%A4%87%E4%BB%BD%E4%B8%8E%E8%BF%98%E5%8E%9F">#</a>备份与还原</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br></pre></td><td class="code"><pre><code class="hljs mysql">/* 备份与还原 */ ------------------<br>备份，将数据的结构与表内数据保存起来。<br>利用 mysqldump 指令完成。<br>-- 导出<br>mysqldump [options] db_name [tables]<br>mysqldump [options] ---database DB1 [DB2 DB3...]<br>mysqldump [options] --all--database<br>1. 导出一张表<br>　　mysqldump -u用户名 -p密码 库名 表名 &gt; 文件名(D:/a.sql)<br>2. 导出多张表<br>　　mysqldump -u用户名 -p密码 库名 表1 表2 表3 &gt; 文件名(D:/a.sql)<br>3. 导出所有表<br>　　mysqldump -u用户名 -p密码 库名 &gt; 文件名(D:/a.sql)<br>4. 导出一个库<br>　　mysqldump -u用户名 -p密码 --lock-all-tables --database 库名 &gt; 文件名(D:/a.sql)<br>可以-w携带WHERE条件<br>-- 导入<br>1. 在登录mysql的情况下：<br>　　source  备份文件<br>2. 在不登录的情况下<br>　　mysql -u用户名 -p密码 库名 &lt; 备份文件<br></code></pre></td></tr></table></figure>
<h3 id="-15"><a class="markdownIt-Anchor" href="#-15"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#%E8%A7%86%E5%9B%BE">#</a>视图</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br><span class="line">24</span><br><span class="line">25</span><br><span class="line">26</span><br><span class="line">27</span><br><span class="line">28</span><br><span class="line">29</span><br></pre></td><td class="code"><pre><code class="hljs mysql">什么是视图：<br>    视图是一个虚拟表，其内容由查询定义。同真实的表一样，视图包含一系列带有名称的列和行数据。但是，视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表，并且在引用视图时动态生成。<br>    视图具有表结构文件，但不存在数据文件。<br>    对其中所引用的基础表来说，视图的作用类似于筛选。定义视图的筛选可以来自当前或其它数据库的一个或多个表，或者其它视图。通过视图进行查询没有任何限制，通过它们进行数据修改时的限制也很少。<br>    视图是存储在数据库中的查询的sql语句，它主要出于两种原因：安全原因，视图可以隐藏一些数据，如：社会保险基金表，可以用视图只显示姓名，地址，而不显示社会保险号和工资数等，另一原因是可使复杂的查询易于理解和使用。<br>-- 创建视图<br>CREATE [OR REPLACE] [ALGORITHM = &#123;UNDEFINED | MERGE | TEMPTABLE&#125;] VIEW view_name [(column_list)] AS select_statement<br>    - 视图名必须唯一，同时不能与表重名。<br>    - 视图可以使用select语句查询到的列名，也可以自己指定相应的列名。<br>    - 可以指定视图执行的算法，通过ALGORITHM指定。<br>    - column_list如果存在，则数目必须等于SELECT语句检索的列数<br>-- 查看结构<br>    SHOW CREATE VIEW view_name<br>-- 删除视图<br>    - 删除视图后，数据依然存在。<br>    - 可同时删除多个视图。<br>    DROP VIEW [IF EXISTS] view_name ...<br>-- 修改视图结构<br>    - 一般不修改视图，因为不是所有的更新视图都会映射到表上。<br>    ALTER VIEW view_name [(column_list)] AS select_statement<br>-- 视图作用<br>    1. 简化业务逻辑<br>    2. 对客户端隐藏真实的表结构<br>-- 视图算法(ALGORITHM)<br>    MERGE       合并<br>        将视图的查询语句，与外部查询需要先合并再执行！<br>    TEMPTABLE   临时表<br>        将视图执行完毕后，形成临时表，再做外层查询！<br>    UNDEFINED   未定义(默认)，指的是MySQL自主去选择相应的算法。<br></code></pre></td></tr></table></figure>
<h3 id="-16"><a class="markdownIt-Anchor" href="#-16"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#%E4%BA%8B%E5%8A%A1-transaction">#</a>事务(transaction)</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br><span class="line">24</span><br><span class="line">25</span><br><span class="line">26</span><br><span class="line">27</span><br><span class="line">28</span><br><span class="line">29</span><br><span class="line">30</span><br><span class="line">31</span><br><span class="line">32</span><br><span class="line">33</span><br><span class="line">34</span><br><span class="line">35</span><br><span class="line">36</span><br><span class="line">37</span><br><span class="line">38</span><br><span class="line">39</span><br><span class="line">40</span><br><span class="line">41</span><br><span class="line">42</span><br><span class="line">43</span><br><span class="line">44</span><br><span class="line">45</span><br></pre></td><td class="code"><pre><code class="hljs mysql">事务是指逻辑上的一组操作，组成这组操作的各个单元，要不全成功要不全失败。<br>    - 支持连续SQL的集体成功或集体撤销。<br>    - 事务是数据库在数据完整性方面的一个功能。<br>    - 需要利用 InnoDB 或 BDB 存储引擎，对自动提交的特性支持完成。<br>    - InnoDB被称为事务安全型引擎。<br>-- 事务开启<br>    START TRANSACTION; 或者 BEGIN;<br>    开启事务后，所有被执行的SQL语句均被认作当前事务内的SQL语句。<br>-- 事务提交<br>    COMMIT;<br>-- 事务回滚<br>    ROLLBACK;<br>    如果部分操作发生问题，映射到事务开启前。<br>-- 事务的特性<br>    1. 原子性（Atomicity）<br>        事务是一个不可分割的工作单位，事务中的操作要么都发生，要么都不发生。<br>    2. 一致性（Consistency）<br>        事务前后数据的完整性必须保持一致。<br>        - 事务开始和结束时，外部数据一致<br>        - 在整个事务过程中，操作是连续的<br>    3. 隔离性（Isolation）<br>        多个用户并发访问数据库时，一个用户的事务不能被其它用户的事务所干扰，多个并发事务之间的数据要相互隔离。<br>    4. 持久性（Durability）<br>        一个事务一旦被提交，它对数据库中的数据改变就是永久性的。<br>-- 事务的实现<br>    1. 要求是事务支持的表类型<br>    2. 执行一组相关的操作前开启事务<br>    3. 整组操作完成后，都成功，则提交；如果存在失败，选择回滚，则会回到事务开始的备份点。<br>-- 事务的原理<br>    利用InnoDB的自动提交(autocommit)特性完成。<br>    普通的MySQL执行语句后，当前的数据提交操作均可被其他客户端可见。<br>    而事务是暂时关闭“自动提交”机制，需要commit提交持久化数据操作。<br>-- 注意<br>    1. 数据定义语言（DDL）语句不能被回滚，比如创建或取消数据库的语句，和创建、取消或更改表或存储的子程序的语句。<br>    2. 事务不能被嵌套<br>-- 保存点<br>    SAVEPOINT 保存点名称 -- 设置一个事务保存点<br>    ROLLBACK TO SAVEPOINT 保存点名称 -- 回滚到保存点<br>    RELEASE SAVEPOINT 保存点名称 -- 删除保存点<br>-- InnoDB自动提交特性设置<br>    SET autocommit = 0|1;   0表示关闭自动提交，1表示开启自动提交。<br>    - 如果关闭了，那普通操作的结果对其他客户端也不可见，需要commit提交后才能持久化数据操作。<br>    - 也可以关闭自动提交来开启事务。但与START TRANSACTION不同的是，<br>        SET autocommit是永久改变服务器的设置，直到下次再次修改该设置。(针对当前连接)<br>        而START TRANSACTION记录开启前的状态，而一旦事务提交或回滚后就需要再次开启事务。(针对当前事务)<br></code></pre></td></tr></table></figure>
<h3 id="-17"><a class="markdownIt-Anchor" href="#-17"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#%E9%94%81%E8%A1%A8">#</a>锁表</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br></pre></td><td class="code"><pre><code class="hljs mysql">/* 锁表 */<br>表锁定只用于防止其它客户端进行不正当地读取和写入<br>MyISAM 支持表锁，InnoDB 支持行锁<br>-- 锁定<br>    LOCK TABLES tbl_name [AS alias]<br>-- 解锁<br>    UNLOCK TABLES<br></code></pre></td></tr></table></figure>
<h3 id="-18"><a class="markdownIt-Anchor" href="#-18"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#%E8%A7%A6%E5%8F%91%E5%99%A8">#</a>触发器</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br><span class="line">24</span><br><span class="line">25</span><br><span class="line">26</span><br><span class="line">27</span><br><span class="line">28</span><br><span class="line">29</span><br><span class="line">30</span><br><span class="line">31</span><br><span class="line">32</span><br><span class="line">33</span><br><span class="line">34</span><br><span class="line">35</span><br><span class="line">36</span><br><span class="line">37</span><br><span class="line">38</span><br><span class="line">39</span><br><span class="line">40</span><br><span class="line">41</span><br><span class="line">42</span><br><span class="line">43</span><br><span class="line">44</span><br><span class="line">45</span><br><span class="line">46</span><br><span class="line">47</span><br><span class="line">48</span><br></pre></td><td class="code"><pre><code class="hljs mysql">/* 触发器 */ ------------------<br>    触发程序是与表有关的命名数据库对象，当该表出现特定事件时，将激活该对象<br>    监听：记录的增加、修改、删除。<br>-- 创建触发器<br>CREATE TRIGGER trigger_name trigger_time trigger_event ON tbl_name FOR EACH ROW trigger_stmt<br>    参数：<br>    trigger_time是触发程序的动作时间。它可以是 before 或 after，以指明触发程序是在激活它的语句之前或之后触发。<br>    trigger_event指明了激活触发程序的语句的类型<br>        INSERT：将新行插入表时激活触发程序<br>        UPDATE：更改某一行时激活触发程序<br>        DELETE：从表中删除某一行时激活触发程序<br>    tbl_name：监听的表，必须是永久性的表，不能将触发程序与TEMPORARY表或视图关联起来。<br>    trigger_stmt：当触发程序激活时执行的语句。执行多个语句，可使用BEGIN...END复合语句结构<br>-- 删除<br>DROP TRIGGER [schema_name.]trigger_name<br>可以使用old和new代替旧的和新的数据<br>    更新操作，更新前是old，更新后是new.<br>    删除操作，只有old.<br>    增加操作，只有new.<br>-- 注意<br>    1. 对于具有相同触发程序动作时间和事件的给定表，不能有两个触发程序。<br>-- 字符连接函数<br>concat(str1,str2,...])<br>concat_ws(separator,str1,str2,...)<br>-- 分支语句<br>if 条件 then<br>    执行语句<br>elseif 条件 then<br>    执行语句<br>else<br>    执行语句<br>end if;<br>-- 修改最外层语句结束符<br>delimiter 自定义结束符号<br>    SQL语句<br>自定义结束符号<br>delimiter ;     -- 修改回原来的分号<br>-- 语句块包裹<br>begin<br>    语句块<br>end<br>-- 特殊的执行<br>1. 只要添加记录，就会触发程序。<br>2. Insert into on duplicate key update 语法会触发：<br>    如果没有重复记录，会触发 before insert, after insert;<br>    如果有重复记录并更新，会触发 before insert, before update, after update;<br>    如果有重复记录但是没有发生更新，则触发 before insert, before update<br>3. Replace 语法 如果有记录，则执行 before insert, before delete, after delete, after insert<br></code></pre></td></tr></table></figure>
<h3 id="-19"><a class="markdownIt-Anchor" href="#-19"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#sql%E7%BC%96%E7%A8%8B">#</a>SQL编程</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br><span class="line">24</span><br><span class="line">25</span><br><span class="line">26</span><br><span class="line">27</span><br><span class="line">28</span><br><span class="line">29</span><br><span class="line">30</span><br><span class="line">31</span><br><span class="line">32</span><br><span class="line">33</span><br><span class="line">34</span><br><span class="line">35</span><br><span class="line">36</span><br><span class="line">37</span><br><span class="line">38</span><br><span class="line">39</span><br><span class="line">40</span><br><span class="line">41</span><br><span class="line">42</span><br><span class="line">43</span><br><span class="line">44</span><br><span class="line">45</span><br><span class="line">46</span><br><span class="line">47</span><br><span class="line">48</span><br><span class="line">49</span><br><span class="line">50</span><br><span class="line">51</span><br><span class="line">52</span><br><span class="line">53</span><br><span class="line">54</span><br><span class="line">55</span><br><span class="line">56</span><br><span class="line">57</span><br><span class="line">58</span><br><span class="line">59</span><br><span class="line">60</span><br><span class="line">61</span><br><span class="line">62</span><br><span class="line">63</span><br><span class="line">64</span><br><span class="line">65</span><br><span class="line">66</span><br><span class="line">67</span><br><span class="line">68</span><br><span class="line">69</span><br><span class="line">70</span><br><span class="line">71</span><br><span class="line">72</span><br><span class="line">73</span><br><span class="line">74</span><br><span class="line">75</span><br><span class="line">76</span><br><span class="line">77</span><br><span class="line">78</span><br><span class="line">79</span><br><span class="line">80</span><br><span class="line">81</span><br><span class="line">82</span><br><span class="line">83</span><br><span class="line">84</span><br><span class="line">85</span><br><span class="line">86</span><br><span class="line">87</span><br><span class="line">88</span><br><span class="line">89</span><br><span class="line">90</span><br><span class="line">91</span><br><span class="line">92</span><br><span class="line">93</span><br><span class="line">94</span><br><span class="line">95</span><br><span class="line">96</span><br><span class="line">97</span><br><span class="line">98</span><br><span class="line">99</span><br><span class="line">100</span><br><span class="line">101</span><br><span class="line">102</span><br><span class="line">103</span><br><span class="line">104</span><br><span class="line">105</span><br><span class="line">106</span><br><span class="line">107</span><br><span class="line">108</span><br><span class="line">109</span><br><span class="line">110</span><br><span class="line">111</span><br><span class="line">112</span><br><span class="line">113</span><br><span class="line">114</span><br><span class="line">115</span><br><span class="line">116</span><br><span class="line">117</span><br><span class="line">118</span><br><span class="line">119</span><br><span class="line">120</span><br><span class="line">121</span><br><span class="line">122</span><br><span class="line">123</span><br><span class="line">124</span><br><span class="line">125</span><br><span class="line">126</span><br><span class="line">127</span><br><span class="line">128</span><br><span class="line">129</span><br><span class="line">130</span><br></pre></td><td class="code"><pre><code class="hljs mysql">/* SQL编程 */ ------------------<br>--// 局部变量 ----------<br>-- 变量声明<br>    declare var_name[,...] type [default value]<br>    这个语句被用来声明局部变量。要给变量提供一个默认值，请包含一个default子句。值可以被指定为一个表达式，不需要为一个常数。如果没有default子句，初始值为null。<br>-- 赋值<br>    使用 set 和 select into 语句为变量赋值。<br>    - 注意：在函数内是可以使用全局变量（用户自定义的变量）<br>--// 全局变量 ----------<br>-- 定义、赋值<br>set 语句可以定义并为变量赋值。<br>set @var = value;<br>也可以使用select into语句为变量初始化并赋值。这样要求select语句只能返回一行，但是可以是多个字段，就意味着同时为多个变量进行赋值，变量的数量需要与查询的列数一致。<br>还可以把赋值语句看作一个表达式，通过select执行完成。此时为了避免=被当作关系运算符看待，使用:=代替。（set语句可以使用= 和 :=）。<br>select @var:=20;<br>select @v1:=id, @v2=name from t1 limit 1;<br>select * from tbl_name where @var:=30;<br>select into 可以将表中查询获得的数据赋给变量。<br>    -| select max(height) into @max_height from tb;<br>-- 自定义变量名<br>为了避免select语句中，用户自定义的变量与系统标识符（通常是字段名）冲突，用户自定义变量在变量名前使用@作为开始符号。<br>@var=10;<br>    - 变量被定义后，在整个会话周期都有效（登录到退出）<br>--// 控制结构 ----------<br>-- if语句<br>if search_condition then<br>    statement_list   <br>[elseif search_condition then<br>    statement_list]<br>...<br>[else<br>    statement_list]<br>end if;<br>-- case语句<br>CASE value WHEN [compare-value] THEN result<br>[WHEN [compare-value] THEN result ...]<br>[ELSE result]<br>END<br>-- while循环<br>[begin_label:] while search_condition do<br>    statement_list<br>end while [end_label];<br>- 如果需要在循环内提前终止 while循环，则需要使用标签；标签需要成对出现。<br>    -- 退出循环<br>        退出整个循环 leave<br>        退出当前循环 iterate<br>        通过退出的标签决定退出哪个循环<br>--// 内置函数 ----------<br>-- 数值函数<br>abs(x)          -- 绝对值 abs(-10.9) = 10<br>format(x, d)    -- 格式化千分位数值 format(1234567.456, 2) = 1,234,567.46<br>ceil(x)         -- 向上取整 ceil(10.1) = 11<br>floor(x)        -- 向下取整 floor (10.1) = 10<br>round(x)        -- 四舍五入去整<br>mod(m, n)       -- m%n m mod n 求余 10%3=1<br>pi()            -- 获得圆周率<br>pow(m, n)       -- m^n<br>sqrt(x)         -- 算术平方根<br>rand()          -- 随机数<br>truncate(x, d)  -- 截取d位小数<br>-- 时间日期函数<br>now(), current_timestamp();     -- 当前日期时间<br>current_date();                 -- 当前日期<br>current_time();                 -- 当前时间<br>date(&#x27;yyyy-mm-dd hh:ii:ss&#x27;);    -- 获取日期部分<br>time(&#x27;yyyy-mm-dd hh:ii:ss&#x27;);    -- 获取时间部分<br>date_format(&#x27;yyyy-mm-dd hh:ii:ss&#x27;, &#x27;%d %y %a %d %m %b %j&#x27;); -- 格式化时间<br>unix_timestamp();               -- 获得unix时间戳<br>from_unixtime();                -- 从时间戳获得时间<br>-- 字符串函数<br>length(string)          -- string长度，字节<br>char_length(string)     -- string的字符个数<br>substring(str, position [,length])      -- 从str的position开始,取length个字符<br>replace(str ,search_str ,replace_str)   -- 在str中用replace_str替换search_str<br>instr(string ,substring)    -- 返回substring首次在string中出现的位置<br>concat(string [,...])   -- 连接字串<br>charset(str)            -- 返回字串字符集<br>lcase(string)           -- 转换成小写<br>left(string, length)    -- 从string2中的左边起取length个字符<br>load_file(file_name)    -- 从文件读取内容<br>locate(substring, string [,start_position]) -- 同instr,但可指定开始位置<br>lpad(string, length, pad)   -- 重复用pad加在string开头,直到字串长度为length<br>ltrim(string)           -- 去除前端空格<br>repeat(string, count)   -- 重复count次<br>rpad(string, length, pad)   --在str后用pad补充,直到长度为length<br>rtrim(string)           -- 去除后端空格<br>strcmp(string1 ,string2)    -- 逐字符比较两字串大小<br>-- 流程函数<br>case when [condition] then result [when [condition] then result ...] [else result] end   多分支<br>if(expr1,expr2,expr3)  双分支。<br>-- 聚合函数<br>count()<br>sum();<br>max();<br>min();<br>avg();<br>group_concat()<br>-- 其他常用函数<br>md5();<br>default();<br>--// 存储函数，自定义函数 ----------<br>-- 新建<br>    CREATE FUNCTION function_name (参数列表) RETURNS 返回值类型<br>        函数体<br>    - 函数名，应该合法的标识符，并且不应该与已有的关键字冲突。<br>    - 一个函数应该属于某个数据库，可以使用db_name.funciton_name的形式执行当前函数所属数据库，否则为当前数据库。<br>    - 参数部分，由&quot;参数名&quot;和&quot;参数类型&quot;组成。多个参数用逗号隔开。<br>    - 函数体由多条可用的mysql语句，流程控制，变量声明等语句构成。<br>    - 多条语句应该使用 begin...end 语句块包含。<br>    - 一定要有 return 返回值语句。<br>-- 删除<br>    DROP FUNCTION [IF EXISTS] function_name;<br>-- 查看<br>    SHOW FUNCTION STATUS LIKE &#x27;partten&#x27;<br>    SHOW CREATE FUNCTION function_name;<br>-- 修改<br>    ALTER FUNCTION function_name 函数选项<br>--// 存储过程，自定义功能 ----------<br>-- 定义<br>存储存储过程 是一段代码（过程），存储在数据库中的sql组成。<br>一个存储过程通常用于完成一段业务逻辑，例如报名，交班费，订单入库等。<br>而一个函数通常专注与某个功能，视为其他程序服务的，需要在其他语句中调用函数才可以，而存储过程不能被其他调用，是自己执行 通过call执行。<br>-- 创建<br>CREATE PROCEDURE sp_name (参数列表)<br>    过程体<br>参数列表：不同于函数的参数列表，需要指明参数类型<br>IN，表示输入型<br>OUT，表示输出型<br>INOUT，表示混合型<br>注意，没有返回值。<br></code></pre></td></tr></table></figure>
<h3 id="-20"><a class="markdownIt-Anchor" href="#-20"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#%E5%AD%98%E5%82%A8%E8%BF%87%E7%A8%8B">#</a>存储过程</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br></pre></td><td class="code"><pre><code class="hljs mysql">/* 存储过程 */ ------------------<br>存储过程是一段可执行性代码的集合。相比函数，更偏向于业务逻辑。<br>调用：CALL 过程名<br>-- 注意<br>- 没有返回值。<br>- 只能单独调用，不可夹杂在其他语句中<br>-- 参数<br>IN|OUT|INOUT 参数名 数据类型<br>IN      输入：在调用过程中，将数据输入到过程体内部的参数<br>OUT     输出：在调用过程中，将过程体处理完的结果返回到客户端<br>INOUT   输入输出：既可输入，也可输出<br>-- 语法<br>CREATE PROCEDURE 过程名 (参数列表)<br>BEGIN<br>    过程体<br>END<br></code></pre></td></tr></table></figure>
<h3 id="-21"><a class="markdownIt-Anchor" href="#-21"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#%E7%94%A8%E6%88%B7%E5%92%8C%E6%9D%83%E9%99%90%E7%AE%A1%E7%90%86">#</a>用户和权限管理</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br><span class="line">15</span><br><span class="line">16</span><br><span class="line">17</span><br><span class="line">18</span><br><span class="line">19</span><br><span class="line">20</span><br><span class="line">21</span><br><span class="line">22</span><br><span class="line">23</span><br><span class="line">24</span><br><span class="line">25</span><br><span class="line">26</span><br><span class="line">27</span><br><span class="line">28</span><br><span class="line">29</span><br><span class="line">30</span><br><span class="line">31</span><br><span class="line">32</span><br><span class="line">33</span><br><span class="line">34</span><br><span class="line">35</span><br><span class="line">36</span><br><span class="line">37</span><br><span class="line">38</span><br><span class="line">39</span><br><span class="line">40</span><br><span class="line">41</span><br><span class="line">42</span><br><span class="line">43</span><br><span class="line">44</span><br><span class="line">45</span><br><span class="line">46</span><br><span class="line">47</span><br><span class="line">48</span><br><span class="line">49</span><br><span class="line">50</span><br><span class="line">51</span><br><span class="line">52</span><br><span class="line">53</span><br><span class="line">54</span><br><span class="line">55</span><br><span class="line">56</span><br><span class="line">57</span><br><span class="line">58</span><br><span class="line">59</span><br><span class="line">60</span><br><span class="line">61</span><br><span class="line">62</span><br><span class="line">63</span><br><span class="line">64</span><br><span class="line">65</span><br><span class="line">66</span><br><span class="line">67</span><br><span class="line">68</span><br><span class="line">69</span><br><span class="line">70</span><br><span class="line">71</span><br><span class="line">72</span><br><span class="line">73</span><br><span class="line">74</span><br><span class="line">75</span><br><span class="line">76</span><br><span class="line">77</span><br></pre></td><td class="code"><pre><code class="hljs mysql">/* 用户和权限管理 */ ------------------<br>-- root密码重置<br>1. 停止MySQL服务<br>2.  [Linux] /usr/local/mysql/bin/safe_mysqld --skip-grant-tables &amp;<br>    [Windows] mysqld --skip-grant-tables<br>3. use mysql;<br>4. UPDATE `user` SET PASSWORD=PASSWORD(&quot;密码&quot;) WHERE `user` = &quot;root&quot;;<br>5. FLUSH PRIVILEGES;<br>用户信息表：mysql.user<br>-- 刷新权限<br>FLUSH PRIVILEGES;<br>-- 增加用户<br>CREATE USER 用户名 IDENTIFIED BY [PASSWORD] 密码(字符串)<br>    - 必须拥有mysql数据库的全局CREATE USER权限，或拥有INSERT权限。<br>    - 只能创建用户，不能赋予权限。<br>    - 用户名，注意引号：如 &#x27;user_name&#x27;@&#x27;192.168.1.1&#x27;<br>    - 密码也需引号，纯数字密码也要加引号<br>    - 要在纯文本中指定密码，需忽略PASSWORD关键词。要把密码指定为由PASSWORD()函数返回的混编值，需包含关键字PASSWORD<br>-- 重命名用户<br>RENAME USER old_user TO new_user<br>-- 设置密码<br>SET PASSWORD = PASSWORD(&#x27;密码&#x27;)  -- 为当前用户设置密码<br>SET PASSWORD FOR 用户名 = PASSWORD(&#x27;密码&#x27;) -- 为指定用户设置密码<br>-- 删除用户<br>DROP USER 用户名<br>-- 分配权限/添加用户<br>GRANT 权限列表 ON 表名 TO 用户名 [IDENTIFIED BY [PASSWORD] &#x27;password&#x27;]<br>    - all privileges 表示所有权限<br>    - *.* 表示所有库的所有表<br>    - 库名.表名 表示某库下面的某表<br>    GRANT ALL PRIVILEGES ON `pms`.* TO &#x27;pms&#x27;@&#x27;%&#x27; IDENTIFIED BY &#x27;pms0817&#x27;;<br>-- 查看权限<br>SHOW GRANTS FOR 用户名<br>    -- 查看当前用户权限<br>    SHOW GRANTS; 或 SHOW GRANTS FOR CURRENT_USER; 或 SHOW GRANTS FOR CURRENT_USER();<br>-- 撤消权限<br>REVOKE 权限列表 ON 表名 FROM 用户名<br>REVOKE ALL PRIVILEGES, GRANT OPTION FROM 用户名   -- 撤销所有权限<br>-- 权限层级<br>-- 要使用GRANT或REVOKE，您必须拥有GRANT OPTION权限，并且您必须用于您正在授予或撤销的权限。<br>全局层级：全局权限适用于一个给定服务器中的所有数据库，mysql.user<br>    GRANT ALL ON *.*和 REVOKE ALL ON *.*只授予和撤销全局权限。<br>数据库层级：数据库权限适用于一个给定数据库中的所有目标，mysql.db, mysql.host<br>    GRANT ALL ON db_name.*和REVOKE ALL ON db_name.*只授予和撤销数据库权限。<br>表层级：表权限适用于一个给定表中的所有列，mysql.talbes_priv<br>    GRANT ALL ON db_name.tbl_name和REVOKE ALL ON db_name.tbl_name只授予和撤销表权限。<br>列层级：列权限适用于一个给定表中的单一列，mysql.columns_priv<br>    当使用REVOKE时，您必须指定与被授权列相同的列。<br>-- 权限列表<br>ALL [PRIVILEGES]    -- 设置除GRANT OPTION之外的所有简单权限<br>ALTER   -- 允许使用ALTER TABLE<br>ALTER ROUTINE   -- 更改或取消已存储的子程序<br>CREATE  -- 允许使用CREATE TABLE<br>CREATE ROUTINE  -- 创建已存储的子程序<br>CREATE TEMPORARY TABLES     -- 允许使用CREATE TEMPORARY TABLE<br>CREATE USER     -- 允许使用CREATE USER, DROP USER, RENAME USER和REVOKE ALL PRIVILEGES。<br>CREATE VIEW     -- 允许使用CREATE VIEW<br>DELETE  -- 允许使用DELETE<br>DROP    -- 允许使用DROP TABLE<br>EXECUTE     -- 允许用户运行已存储的子程序<br>FILE    -- 允许使用SELECT...INTO OUTFILE和LOAD DATA INFILE<br>INDEX   -- 允许使用CREATE INDEX和DROP INDEX<br>INSERT  -- 允许使用INSERT<br>LOCK TABLES     -- 允许对您拥有SELECT权限的表使用LOCK TABLES<br>PROCESS     -- 允许使用SHOW FULL PROCESSLIST<br>REFERENCES  -- 未被实施<br>RELOAD  -- 允许使用FLUSH<br>REPLICATION CLIENT  -- 允许用户询问从属服务器或主服务器的地址<br>REPLICATION SLAVE   -- 用于复制型从属服务器（从主服务器中读取二进制日志事件）<br>SELECT  -- 允许使用SELECT<br>SHOW DATABASES  -- 显示所有数据库<br>SHOW VIEW   -- 允许使用SHOW CREATE VIEW<br>SHUTDOWN    -- 允许使用mysqladmin shutdown<br>SUPER   -- 允许使用CHANGE MASTER, KILL, PURGE MASTER LOGS和SET GLOBAL语句，mysqladmin debug命令；允许您连接（一次），即使已达到max_connections。<br>UPDATE  -- 允许使用UPDATE<br>USAGE   -- “无权限”的同义词<br>GRANT OPTION    -- 允许授予权限<br></code></pre></td></tr></table></figure>
<h3 id="-22"><a class="markdownIt-Anchor" href="#-22"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#%E8%A1%A8%E7%BB%B4%E6%8A%A4">#</a>表维护</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br></pre></td><td class="code"><pre><code class="hljs mysql">/* 表维护 */<br>-- 分析和存储表的关键字分布<br>ANALYZE [LOCAL | NO_WRITE_TO_BINLOG] TABLE 表名 ...<br>-- 检查一个或多个表是否有错误<br>CHECK TABLE tbl_name [, tbl_name] ... [option] ...<br>option = &#123;QUICK | FAST | MEDIUM | EXTENDED | CHANGED&#125;<br>-- 整理数据文件的碎片<br>OPTIMIZE [LOCAL | NO_WRITE_TO_BINLOG] TABLE tbl_name [, tbl_name] ...<br></code></pre></td></tr></table></figure>
<h3 id="-23"><a class="markdownIt-Anchor" href="#-23"></a> <a target="_blank" rel="noopener" href="https://javaguide.cn/database/mysql/a-thousand-lines-of-mysql-study-notes.html#%E6%9D%82%E9%A1%B9">#</a>杂项</h3>
<figure class="highlight plaintext"><table><tr><td class="gutter"><pre><span class="line">1</span><br><span class="line">2</span><br><span class="line">3</span><br><span class="line">4</span><br><span class="line">5</span><br><span class="line">6</span><br><span class="line">7</span><br><span class="line">8</span><br><span class="line">9</span><br><span class="line">10</span><br><span class="line">11</span><br><span class="line">12</span><br><span class="line">13</span><br><span class="line">14</span><br></pre></td><td class="code"><pre><code class="hljs mysql">/* 杂项 */ ------------------<br>1. 可用反引号（`）为标识符（库名、表名、字段名、索引、别名）包裹，以避免与关键字重名！中文也可以作为标识符！<br>2. 每个库目录存在一个保存当前数据库的选项文件db.opt。<br>3. 注释：<br>    单行注释 # 注释内容<br>    多行注释 /* 注释内容 */<br>    单行注释 -- 注释内容     (标准SQL注释风格，要求双破折号后加一空格符（空格、TAB、换行等）)<br>4. 模式通配符：<br>    _   任意单个字符<br>    %   任意多个字符，甚至包括零字符<br>    单引号需要进行转义 \&#x27;<br>5. CMD命令行内的语句结束符可以为 &quot;;&quot;, &quot;\G&quot;, &quot;\g&quot;，仅影响显示结果。其他地方还是用分号结束。delimiter 可修改当前对话的语句结束符。<br>6. SQL对大小写不敏感<br>7. 清除已有语句：\c<br></code></pre></td></tr></table></figure>

                
              </div>
            
            <hr/>
            <div>
              <div class="post-metas my-3">
  
    <div class="post-meta mr-3 d-flex align-items-center">
      <i class="iconfont icon-category"></i>
      

<span class="category-chains">
  
  
    
      <span class="category-chain">
        
  <a href="/categories/%E6%95%B0%E6%8D%AE%E5%BA%93/" class="category-chain-item">数据库</a>
  
  
    <span>></span>
    
  <a href="/categories/%E6%95%B0%E6%8D%AE%E5%BA%93/MySQL/" class="category-chain-item">MySQL</a>
  
  

  

      </span>
    
  
</span>

    </div>
  
  
    <div class="post-meta">
      <i class="iconfont icon-tags"></i>
      
        <a href="/tags/MySQL/">#MySQL</a>
      
    </div>
  
</div>


              
  

  <div class="license-box my-3">
    <div class="license-title">
      <div>Mysql学习笔记</div>
      <div>http://example.com/2022/04/06/20220406-Mysql学习笔记/</div>
    </div>
    <div class="license-meta">
      
        <div class="license-meta-item">
          <div>作者</div>
          <div>叶飞</div>
        </div>
      
      
        <div class="license-meta-item license-meta-date">
          <div>发布于</div>
          <div>2022年4月6日</div>
        </div>
      
      
      <div class="license-meta-item">
        <div>许可协议</div>
        <div>
          
            
            
              <a target="_blank" href="https://creativecommons.org/licenses/by/4.0/">
              <span class="hint--top hint--rounded" aria-label="BY - 署名">
                <i class="iconfont icon-by"></i>
              </span>
              </a>
            
          
        </div>
      </div>
    </div>
    <div class="license-icon iconfont"></div>
  </div>



              
                <div class="post-prevnext my-3">
                  <article class="post-prev col-6">
                    
                    
                      <a href="/2022/04/06/20220406-RestfulAPI/" title="RestfulAPI">
                        <i class="iconfont icon-arrowleft"></i>
                        <span class="hidden-mobile">RestfulAPI</span>
                        <span class="visible-mobile">上一篇</span>
                      </a>
                    
                  </article>
                  <article class="post-next col-6">
                    
                    
                      <a href="/2022/04/05/20220405-MySQL%E5%B8%B8%E8%A7%81%E9%9D%A2%E8%AF%95%E9%A2%98-3/" title="MySQL常见面试题-3">
                        <span class="hidden-mobile">MySQL常见面试题-3</span>
                        <span class="visible-mobile">下一篇</span>
                        <i class="iconfont icon-arrowright"></i>
                      </a>
                    
                  </article>
                </div>
              
            </div>

            
          </article>
        </div>
      </div>
    </div>

    <div class="side-col d-none d-lg-block col-lg-2">
      
  <aside class="sidebar" style="margin-left: -1rem">
    <div id="toc">
  <p class="toc-header"><i class="iconfont icon-list"></i>&nbsp;目录</p>
  <div class="toc-body" id="toc-body"></div>
</div>



  </aside>


    </div>
  </div>
</div>





  



  



  



  



  


  
  









    

    
      <a id="scroll-top-button" aria-label="TOP" href="#" role="button">
        <i class="iconfont icon-arrowup" aria-hidden="true"></i>
      </a>
    

    
      <div class="modal fade" id="modalSearch" tabindex="-1" role="dialog" aria-labelledby="ModalLabel"
     aria-hidden="true">
  <div class="modal-dialog modal-dialog-scrollable modal-lg" role="document">
    <div class="modal-content">
      <div class="modal-header text-center">
        <h4 class="modal-title w-100 font-weight-bold">搜索</h4>
        <button type="button" id="local-search-close" class="close" data-dismiss="modal" aria-label="Close">
          <span aria-hidden="true">&times;</span>
        </button>
      </div>
      <div class="modal-body mx-3">
        <div class="md-form mb-5">
          <input type="text" id="local-search-input" class="form-control validate">
          <label data-error="x" data-success="v" for="local-search-input">关键词</label>
        </div>
        <div class="list-group" id="local-search-result"></div>
      </div>
    </div>
  </div>
</div>

    

    
  </main>

  <footer>
    <div class="footer-inner">
  
    <div class="footer-content">
       <a href="https://hexo.io" target="_blank" rel="nofollow noopener"><span>Hexo</span></a> <i class="iconfont icon-love"></i> <a href="https://github.com/fluid-dev/hexo-theme-fluid" target="_blank" rel="nofollow noopener"><span>Fluid</span></a> 
    </div>
  
  
  
  
</div>

  </footer>

  <!-- Scripts -->
  
  <script  src="https://lib.baomitu.com/nprogress/0.2.0/nprogress.min.js" ></script>
  <link  rel="stylesheet" href="https://lib.baomitu.com/nprogress/0.2.0/nprogress.min.css" />

  <script>
    NProgress.configure({"showSpinner":false,"trickleSpeed":100})
    NProgress.start()
    window.addEventListener('load', function() {
      NProgress.done();
    })
  </script>


<script  src="https://lib.baomitu.com/jquery/3.6.0/jquery.min.js" ></script>
<script  src="https://lib.baomitu.com/twitter-bootstrap/4.6.1/js/bootstrap.min.js" ></script>
<script  src="/js/events.js" ></script>
<script  src="/js/plugins.js" ></script>


  <script  src="https://lib.baomitu.com/typed.js/2.0.12/typed.min.js" ></script>
  <script>
    (function (window, document) {
      var typing = Fluid.plugins.typing;
      var subtitle = document.getElementById('subtitle');
      if (!subtitle || !typing) {
        return;
      }
      var text = subtitle.getAttribute('data-typed-text');
      
        typing(text);
      
    })(window, document);
  </script>




  
    <script  src="/js/img-lazyload.js" ></script>
  




  
<script>
  Fluid.utils.createScript('https://lib.baomitu.com/tocbot/4.18.2/tocbot.min.js', function() {
    var toc = jQuery('#toc');
    if (toc.length === 0 || !window.tocbot) { return; }
    var boardCtn = jQuery('#board-ctn');
    var boardTop = boardCtn.offset().top;

    window.tocbot.init({
      tocSelector     : '#toc-body',
      contentSelector : '.markdown-body',
      headingSelector : CONFIG.toc.headingSelector || 'h1,h2,h3,h4,h5,h6',
      linkClass       : 'tocbot-link',
      activeLinkClass : 'tocbot-active-link',
      listClass       : 'tocbot-list',
      isCollapsedClass: 'tocbot-is-collapsed',
      collapsibleClass: 'tocbot-is-collapsible',
      collapseDepth   : CONFIG.toc.collapseDepth || 0,
      scrollSmooth    : true,
      headingsOffset  : -boardTop
    });
    if (toc.find('.toc-list-item').length > 0) {
      toc.css('visibility', 'visible');
    }
  });
</script>


  <script src=https://lib.baomitu.com/clipboard.js/2.0.10/clipboard.min.js></script>

  <script>Fluid.plugins.codeWidget();</script>


  
<script>
  Fluid.utils.createScript('https://lib.baomitu.com/anchor-js/4.3.1/anchor.min.js', function() {
    window.anchors.options = {
      placement: CONFIG.anchorjs.placement,
      visible  : CONFIG.anchorjs.visible
    };
    if (CONFIG.anchorjs.icon) {
      window.anchors.options.icon = CONFIG.anchorjs.icon;
    }
    var el = (CONFIG.anchorjs.element || 'h1,h2,h3,h4,h5,h6').split(',');
    var res = [];
    for (var item of el) {
      res.push('.markdown-body > ' + item.trim());
    }
    if (CONFIG.anchorjs.placement === 'left') {
      window.anchors.options.class = 'anchorjs-link-left';
    }
    window.anchors.add(res.join(', '));
  });
</script>


  
<script>
  Fluid.utils.createScript('https://lib.baomitu.com/fancybox/3.5.7/jquery.fancybox.min.js', function() {
    Fluid.plugins.fancyBox();
  });
</script>


  <script>Fluid.plugins.imageCaption();</script>

  
      <script>
        if (!window.MathJax) {
          window.MathJax = {
            tex    : {
              inlineMath: { '[+]': [['$', '$']] }
            },
            loader : {
              load: ['ui/lazy']
            },
            options: {
              renderActions: {
                insertedScript: [200, () => {
                  document.querySelectorAll('mjx-container').forEach(node => {
                    let target = node.parentNode;
                    if (target.nodeName.toLowerCase() === 'li') {
                      target.parentNode.classList.add('has-jax');
                    }
                  });
                }, '', false]
              }
            }
          };
        } else {
          MathJax.startup.document.state(0);
          MathJax.texReset();
          MathJax.typeset();
          MathJax.typesetPromise();
        }
      </script>
    

  <script  src="https://lib.baomitu.com/mathjax/3.2.1/es5/tex-mml-chtml.js" ></script>

  <script  src="/js/local-search.js" ></script>

  <script defer src="/js/leancloud.js" ></script>





<!-- 主题的启动项，将它保持在最底部 -->
<!-- the boot of the theme, keep it at the bottom -->
<script  src="/js/boot.js" ></script>


  

  <noscript>
    <div class="noscript-warning">博客在允许 JavaScript 运行的环境下浏览效果更佳</div>
  </noscript>
<script src="/live2dw/lib/L2Dwidget.min.js?094cbace49a39548bed64abff5988b05"></script><script>L2Dwidget.init({"log":false,"pluginJsPath":"lib/","pluginModelPath":"assets/","pluginRootPath":"live2dw/","tagMode":false});</script></body>
</html>
